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Microprocessor  Controlled  Pulse 
Amplitude  Modulation  Decommutator 


I.  INTRODUCTION 

Telemetry  data  frequently  consists  of  housekeeping  monitors,  such  as  temper¬ 
atures  and  battery  voltages,  which  convey  the  internal  status  of  an  airborne  re¬ 
search  payload.  This  information  is  often  telemetered  back  to  the  ground  in  a  PAM 
(Pulse  Amplitude  Modulated)  format  on  one  subcarrier  oscillator  data  channel, 
rather  than  on  a  number  of  channels. 

Present  decommutation  systems  in  use  are  hardwired  logic  boxes  with  limited 
flexibility  and  poor  performance  with  noisy  or  certain  types  of  data.  'Their  output 
is  a  scaled  analog  voltage  suitable  only  for  driving  a  strip  chart  recorder  or  volt¬ 
meter. 

A  microprocessor-based  system  can  provide  a  much  more  reliable  unit  as  well 
as  a  more  flexible  device.  Formats  may  be  changed  by  simply  using  different  soft¬ 
ware.  The  outputs  may  be  scaled,  rnbeled,  and  printed  out  to  display  the  actual 
units  of  the  parameter  being  measured. 

The  KIM-1  microprocessor  evaluation  board  by  MOS  Technology  is  used  as 
the  building  block  to  design  the  prototype  system.  Input,  output,  memory,  and 
display  devices  are  added  as  required. 

A  description  of  the  prototype  system  hardware  and  software  will  b»  presented, 
as  well  as  ideas  for  incorporation  into  the  final  model. 

(Deceived  for  publication  lfi  October  1980) 


2.  OBJECTIVE 


The  object  of  this  report  is  to  present  and  describe  the  application  of  a  micro¬ 
processor  development  board  to  the  task  of  decommutation  of  a  PAM  data  commu¬ 
tator.  The  techniques  presented  will  provide  the  design  background  for  the  develop¬ 
ment  of  an  intelligent  decom  which  will  perform  the  basic  decom  function,  scale  to 
engineering  units,  and  display  on  a  line  printer  the  segment  number,  raw  voltage 
value,  label,  and  actual  engineering  units  of  the  parameter  being  measured. 


3.  BACKGROUND 


Pulse  Amplitude  Modulation  (PAM)  is  a  technique  of  encoding  a  number  of 
analog  signals  on  a  single  analog  line  by  sequentially  sampling  each  individual  sig¬ 
nal.  The  amplitude  of  the  information  channel  pulse  then  becomes  the  analog- 
variable  parameter.  This  process  of  encoding  is  known  as  commutation,  or  time 
division  multiplex.  The  encoded  signal  is  then  normally  applied  to  a  Sub-Carrier 
Oscillator  (SCO)  and  then  mixed  with  other  SCO's  in  a  standard  FM  Multiplex 
Telemetry  Link. 

This  report  is  concerned  specifically  with  a  30-channel  commutator  which 
samples  each  channel  2.  5  times  per  second.  Other  standard  formats  are  also  in 
use.  1  There  are  two  standard  output  formats  for  the  output  signal:  Return  to 
Zero  (RZ)  and  Non-Return  to  Zero  (NRZ).  The  output  format  affects  the  synchron¬ 
ization  pattern  and  the  duty  cycle  of  the  channel  signal.  This  report  deals  only 
with  the  NRZ  format. 

The  synchronization  signal  of  a  2.  3  V  30  NRZ  commutator  is  specified  as  fol¬ 
lows  by  IRIG-106:1 


Channel  No. 

26 

27 

28 

29 

30 


Voltage 

Zero  amplitude 

Full  scale  amplitude 

Full  scale  amplitude 

Full  scale  amplitude 

50  percent  full  scale  or  less 


Channels  1  through  25  are  defined  as  data  channels. 

For  purposes  of  this  report,  zero  amplitude  is  defined  as  0  V  dc,  and  full 
scale  amplitude  is  r> "fined  as  5  V  dc.  This  voltage  is  compatible  with  standard 
commutators  and  SCO's.  All  inputs  to  the  commutator  must  be  scaled,  usually  in 
a  linear  relationship,  between  these  two  values. 


1.  1RIG  Document  106-80  Standards  for  Telemetry  Systems 


Decommutation  is  the  process  of  reconstructing  the  PAM  wavetrain.  This 
process  includes  synchronization,  channel  selection,  and  a  sample  and  hold  process 
for  the  selected  channel(s).  To  improve  this  process,  software  will  be  added  to 
control  the  entire  process,  to  scale  to  original  engineering  units,  label,  and  to 
print  out  the  data  on  a  video  terminal  and  line  printer. 

Several  problems  have  existed  in  the  past  with  the  hardware  oriented  decom¬ 
mutators: 

1.  Difficulty  in  reconstructing  the  timing  clock.  This  is  especially  difficult 
on  an  NRZ  signal  where  the  clock  frequency  is  not  inherent  in  the  wavetrain.  The 
common  technique  is  to  use  a  triggered  oscillator  or  phase  locked  loop,  but  a 
series  of  data  channels  with  equal  voltage  levels  will  often  cause  the  system  to 
lose  lock. 

2.  False  sync  patterns.  It  is  quite  possible  that  a  series  of  data  channels  may 
look  like  the  sync  pattern  during  some  phase  of  the  data  collection.  Judicious 
assignment  of  data  channels  can  help  alleviate  this  problem,  but  is  not  always 
successful. 

3.  Data  comprehension.  When  used  in  a  decision-making  process  dvring 
long  test  sequences,  the  problem  of  sorting  out,  scaling,  and  labeling  the  data  in 
a  meaningful  format  becomes  significant. 

4.  Capacity.  Most  decoms  will  display  only  a  limited  number  of  channels  at 
one  time.  Display  of  all  significant  channels  would  be  desirable. 

4.  DESIGN 

4.1  Derired  Performance 

The  following  features  are  considered  essential  to  the  satisfactory  performance 
of  this  PAM  decommutator: 

1.  Format:  30-segment  NRZ  commutator. 

2.  Channel  Rate:  75  Hz,  that  is,  sample  rate  -  2,  5/s. 

3.  Input  Level:  ±5  V  peak  with  automatic  scaling  of  any  level  less  than  ±5  V. 

4.  A  phase-lock  loop  synchronization  for  control  of  sampling  times. 

5.  Sixteen  analog  outputs  to  display  data  on  strip  chart  recorders. 

6.  Front  panel  control  of  the  channel  numbers  to  be  output  to  the  16  analog 
outputs. 

7.  Front  panel  control  and  display  of  a  selected  channel. 

8.  ASCII  output  to  a  CRT  or  hard-copy  printer  device. 

9.  External  input  for  time  of  year  data  to  be  used  as  a  label  on  hard-copy 
printout. 


10.  ASCII  keyboard  input  to  facilitate  programming  of  output  formatting 
(scaling,  labeling,  etc. ). 

11.  Operation  from  a  117  V  ac  nominal  power  source. 

4.2  Hardware 

The  hardware  described  in  this  section  consists  of  a  general  purpose  micro¬ 
processor  development  system  and  specific  hardware  for  the  decom  application. 

The  actual  decom  instrument  will  consist  of  only  those  parts  required  and  con¬ 
structed  specifically  for  the  application. 

4.  2.  1  DEVELOPMENT  SYSTEM 

The  MOS  Technology  KIM  (Keyboard  Interface  Module)  microprocessor  evalua¬ 
tion  board  is  used  as  a  building  block  for  the  development  system.  This  basic 
board  contains  a  6502  8-bit  microprocessor,  two  6530  RAM/ROM  timer /interface 
chips,  1-K  byte  RAM,  a  keyboard,  6-digit  decimal  display,  serial  ASCII  transmit/ 
receive  port,  and  tape  recorder  input  and  output  ports.  One  of  the  6530  chips  con¬ 
tains  a  monitor  program  in  ROM  which  interfaces  and  controls  the  various  functions 
and  allows  the  user  to  display  memory  addresses  and  change  their  contents.  Addi¬ 
tional  description  of  this  board  and  a  listing  of  the  monitor  program  is  contained  in 
the  KIM-1  User  Manual. 

KIM  is  plugged  into  a  'KIMSI'  mother  board  which  provides  buffering  of  all 
microprocessor  address,  data,  and  control  lines.  It  converts  the  KIM  control 

signals  to  S-100  signals,  and  provides  a  standard  S-100  bus  format  with  expansion/ 

3 

interface  100  pin  connectors. 

Standard  8-K  byte  memory  boards  are  plugged  in  to  provide  RAM  as  necessary. 
Other  boards,  such  as  EPROM,  input,  and  outboard  boards  are  also  plugged  into 
the  mother  board  to  make  a  complete  system. 

Communication  with  the  development  system  is  through  a  standard  20-mA  loop 
serial  ASCII  keyboard  and  display  such  as  a  Teletype®  or  video  terminal.  This 
interface  is  part  of  the  KIM  evaluation  board.  The  KIM  onboard  display  and  key¬ 
board  are  not  used  when  the  external  ASCII  terminal  is  used. 

The  KIM  board  also  provides  a  tape  recorder  interface  which  is  used  as  perm¬ 
anent  mass  program  storage  during  the  development  process. 

The  power  supply  consists  of  two  high-frequency  switching  supplies  that  pro¬ 
vide  5  V  dc  at  10  A  and  ±15  V  dc  at  1.  5  A  for  distribution  to  all  subsystems  via 
the  mother  board. 


2.  KIM-1  User  Manual,  Mos  Technology  Inc. ,  Publication  No.  6500-15B. 

3.  KIMSI  Assembly/Operating  Manual,  Forethought  Products. 
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4.2.2  INTERFACE 


The  various  input  and  output  circuits  are  described  in  this  section.  Figure  1 
is  a  block  diagram  showing  the  configuration  of  these  various  interface  circuits. 
The  address,  data,  and  control  busses  are  considered  as  part  of  the  development 
system,  and  appear  on  the  mother  board.  Detailed  description  and  drawings  of 
the  interface  circuits  are  shown  up  to  the  bus  or  KIM  application  connector,  as 
appropriate,  with  references  to  the  pin  numbers  and  function. 

The  cassette  recorder,  used  for  program  storage,  and  the  video  terminal, 
used  for  input  output  operations,  connect  directly  to  the  KIM  board  and  are 
described  in  the  KIM-1  manual.  “  Interface  cabling  is  shown  in  Figures  2  and  3. 

The  analog  to  digital  converter  accepts  the  amplitude-modulated  wavetrain 
from  the  discriminator  and  converts  it,  under  processor  control,  to  a  digital  count 
each  time  it  is  commanded  to  convert  by  the  deeom  program.  The  converter  used 
is  an  Analog  Devices  model  ADC  102  10-bit  converter,  from  which  only  the  8  most 
significant  bits  are  used.  It  aceepts  a  bipolar  signal  between  -5  and  +5  V  and  out- 

g 

puts  a  proportional  count  between  0  and  255  (2  -11.  The  converter  is  connected 
directly  to  parallel  interface  lines  on  the  KIM  board  as  shown  in  Figure  4. 

The  total  dynamic  errors  inherent  in  an  FM  multiplex  system  (that  is,  those 
that  cannot  be  reduced  or  eliminated  by  calibration!  are  generally  considered  to  be 


Figure  1.  System  Block  Diagram 
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Figure  2.  Tape  Cassette  Interface 
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APPLICATION 
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Figure  3.  Video  Terminal  Interface 


Figure  4.  Analog  to  Digital  Converter  Interface 
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approximately  2  percent,  or  100  mV  for  the  0  to  5  V  input  signal.  The  resolution 
of  an  8-bit  system  digitizing  a  5  V  signal  is  approximately  20  mV,  well  within  the 
overall  system  accuracy.  Even  when  the  discriminator  voltage  swing  is  reduced 
by  one  half,  resulting  in  the  use  of  only  one  half  of  the  available  digital  counts,  the 
resolution  of  the  encoded  signal  becomes  40  mV,  still  well  within  overall  system 
accuracy.  This  is  important  since  the  software  allows  the  discriminator  output  to 
be  set  at  any  voltage  swing  between  ±5  and  ±2.  5  V  with  no  effect  on  system  calibra¬ 
tion  and  negligible  effect  on  overall  system  resolution.  It  should  be  noted  that  an 
input  signal  that  exceeds  ±5  V  is  out  of  range  of  the  converter  and  is  not  acceptable. 

The  time  code  generator  used  in  this  application  is  a  DATUM  model  9310  with 
computer  interface.  This  provides  time  of  day  information  for  labeling  the  data 
output,  and  for  correlation  purposes  later. 

The  time  code  generator  is  interfaced  to  the  microprocessor  through  a  6520 
peripheral  interface  adapter  port.  See  Figure  5.  In  addition  to  the  16  time  of  day 
lines,  3  port  lines  are  provided  to  control  the  computer  interface  on  the  generator. 
Time  is  presented  as  two  parallel  16-bit  words  to  the  port  under  software  control 
of  the  three  control  lines.  The  processor  reads  the  port  8  bits  at  a  time  -id  stores 
the  data  in  memory  for  further  processing. 

The  time  code  generator  is  valuable  for  non-real  time  data  printout  since  the 
IRIG  B  signal  from  a  data  tape  may  be  translated,  read  by  the  processor,  and 
printed  out  with  the  data. 

The  front  panel  thumbwheel  switches  are  used  to  select  one  data  segment  to 
be  displayed  on  the  front  panel  digital  meter.  The  selected  segment  will  also 
appear  on  analog  output  No.  1.  See  Figure  5  for  interface  wiring.  A  low  on  the 
PB1  line  selects  the  MSD  switch  and  a  positive  true  BCD  code  appears  on  PB2- 
PB5.  A  high  on  PB1  selects  the  l.SD  in  the  same  way. 

The  analog  output  ports.  Figure  6,  consist  of  a  6520  peripherial  interface 
port,  a  latch  clock  line  decoder 'selector,  data  latches  for  each  output  port,  8-bit 
digital  to  analog  converters,  and  analog  output  drivers.  Two  output  ports  are 
shown  in  Figure  7.  Additional  latches  are  connected  in  parallel  with  those  shown, 
and  the  appropriate  latch  clock  line  is  connected  to  the  4515  clock  line  selector. 

Up  to  16  analog  output  lines  may  be  connected  in  this  manner.  The  front  panel 
digital  meter  is  connected  to  port  number  1  and  displays  whichever  segment  has 
been  selected  for-  that  port  by  the  front  panel  thumbwheel  switches. 

The  output  drivers  are  connected  to  rear  panel  connectors  and  may  be  used 
to  drive  meters,  ink  pen  recorders,  or  light  beam  recorders.  Nominal  output  is 
0  to  5  V  or  0  to  20  mA. 


4.  KM H  Telemeter  No.  13  Aug  1976. 
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Figure  6.  Thumbwheel  Switch  Interface 


The  sync  light  is  used  to  indicate  when  the  decom  has  synchronized  with  the 
sync  pattern,  and  is  controlled  by  the  logic  level  on  data  register  B,  bit  (i  of  the 
6520  P1A  1  chip. 

The  Asynchronous  Communication  Interface  Adapter  (ACIA)  in  Figure  8  is  a 
bus-oriented  device,  that  is,  it  connects  directly  to  the  processor  bus.  It  is  used 
to  provide  the  data  formatting  and  control  to  interface  serial  asynchronous  data 
communications  information  to  the  microprocessor.  The  configuration  of  Figure  8 
is  for  serial  ASCII  output  to  a  20-mA  loop  device,  such  as  a  printer.  The  ACIA 
accepts  ASCII-encoded  parallel  data  from  the  bus  and  places  it  in  a  buffer.  It  then 
adds  the  required  start  and  stop  bits  and  outputs  a  serial  bit  stream  at  a  baud  rate 
determined  by  the  bit  rate  generator.  Bits  are  set  in  the  internal  status  register 
to  prevent  entering  new  data  before  the  current  character  has  been  transmitted. 
Through  this  device  the  printer  provides  a  permanent  record  of  all  commutator 
segments  in  both  raw  voltage  levels  and  scaled  engineering  units.  Time  tags  and 
appropriate  headings  are  added  to  each  page  of  data. 

The  video  terminal.  Figure  3,  is  interfaced  directly  to  the  KIM  board  in  a 
20-mA  loop  configuration.  The  terminal  is  used  to  communicate  with  the  KIM 
monitor  upon  power  up,  and  provides  an  input  device  for  initializing  the  system. 
When  the  decom  program  is  run,  the  screen  becomes  an  output  device  for  the 
commutator  data. 
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Figure  8.  ACLA  Printer  Driver 


Figure  9.  Address  Decoding 


The  KIM  board  provides  for  storage  and  retrieval  of  programs  on  magnetic 
tape  format,  such  as  a  common  cassette  recorder.  Most  of  the  program  may  be 
stored  in  EPROM  and  will  be  available  upon  power  up.  The  BASIC  program  which 
controls,  scales,  labels,  and  formats  the  data  output  is  subject  to  frequent  change, 
and  therefore  is  stored  on  tape  and  loaded  into  the  RAM  each  time  the  system  is 
initialized.  The  combination  of  EPROM  and  RAM  storage  results  in  a  very 
flexible  system.  Data  format  changes  may  be  made  using  a  BASIC  program  stored 
on  tape  while  those  routines  not  subject  to  change  are  programmed  permanently  in 
the  system. 

All  devices  in  a  G502  processor  system  are  assigned  an  address.  This  process 
of  addressing  a  device  is  known  as  memory-mapped  I/O.  Since  the  microprocessor 
chip  has  1G  address  lines  available  to  address  any  one  of  the  64 -K  addresses, 
additional  decoding  is  required  to  uniquely  define  a  device.  Since  many  systems 
do  not  require  the  entire  64 -K  addresses,  blocks  of  address  may  be  assigned  to  a 
device  in  order  to  simplify  decoding.  See  Figure  9  for  the  address  decoding  circuit 
and  Figure  10  for  a  memory  map  of  the  entire  system. 


HEX  Address 

Assignment 

E000-FFFF 

Not  Used 

C000-DFFF 

EPROM  (PAM  Decom) 

8000-BFFF 

Not  Used 

G000-7FFF 

Input /Output  Devices 

2000-5FFF 

EPROM/RAM  (BASIC) 

1800-1FFF 

KIM  ROM 

1700-17FF 

KIM  I/O  &  Timers 

0400-16FF 

Not  Used 

0200-03FF 

RAM 

0100-01FF 

STACK 

0000-00FF 

Zero  Page 

Figure  10.  System  Memory  Map 


4.3  Software 

The  software  for  this  system  may  be  divided  into  two  very  distinct  sections: 
the  timing-dependent  "foreground  job,"  and  the  "background  job,"  which  is  running 
whenever  the  foreground  job  is  not.  These  two  sections  are  further  broken  down 
into  modular  parts  in  the  following  discussion.  See  Figure  11. 
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Figure  11.  Program  Modules 


4.  3.  1  BACKGROUND  JOB 

The  background  job  is  the  program  that  controls  the  entire  system  operation. 

It  initializes  the  system  upon  power  on  and  directs  the  program  flow  through  the 
various  modules.  Whenever  the  system  is  reset,  control  returns  to  the  background 
job.  See  Figure  12. 

4.3.  1.  1  BASIC  Interpreter 

The  BASIC  interpreter  is  a  program  which  was  purchased  from  Microsoft  Inc. 
for  the  KIM-1  system  to  support  and  execute  programs  written  in  BASIC.  It  was 
incorporated  into  this  system  to  simplify  the  programming  requirements  for  scaling, 
labeling,  and  formatting  the  data  output  to  the  printer.  Various  modifications  have 
been  made  to  it  to  support  the  printer,  to  allow  it  to  operate  in  the  foreground/ 
background  mode,  and  to  allow  it  to  be  placed  in  nonvolatile  memory  (EPROM). 

4.3.  1.2  BASIC  program 

The  BASIC  interpreter  interprets  and  executes  the  BASIC  program  on  a  line 
by  line  basis.  See  Appendix  A  for  a  listing  of  the  BASIC  program  used  on  Project 
BAMM.  The  program  calls  a  series  of  routines  which  actually  execute  the  decom 
program,  read  the  time  of  day  clock,  read  in  the  stored  data  segment  values,  and 
drive  the  printer.  Data  segments  may  be  selectively  displayed  as  required,  labels 
and  scaling  factors  may  be  easily  modified,  and  limit  flags  are  displayed  on  the 
printout  where  appropriate.  Hard  copy  printout  times  may  be  selected  at  any  inter¬ 
val,  or  at  specific  times  as  required.  The  entire  system  may  be  applied  to  a  dif¬ 
ferent  project  or  one  with  multiple  commutators  simply  by  changing  the  BASIC 
program.  Appen^’x  B  contains  samole  data  printout  as  a  result  of  the  program  in 
Appendix  A.  The  use  of  a  high-level  language  such  as  BASIC  in  conjunction  with 
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BACKGROUND  JOB  FLOWCHART 


Figure  12.  Background  Job  Flowchart 
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machine  language  routines  results  in  a  very  effective  compromise  of  flexibility 
(BASIC)  and  operating  speed  (machine  code)  required  in  a  real-time  data  acquisi¬ 
tion  environment. 

4.3.  1.3  PAM  Decom  Program 

The  PAM  decom  program  is  actually  a  machine-code  level  subroutine  that  is 
called  from  the  BASIC  program.  This  program  and  the  interrupt-driven  foreground 
program  are  the  heart  of  this  report. 

The  decom  program  module  does  the  non-time-dependent  segments  of  the 
decommutation  task,  including  the  following: 

1.  Initialize  hardware  and  software. 

2.  Request  entry  of  up  to  16  segment  numbers  for  output  to  analog  output  ports. 

3.  Cheek  Phase  Lock  status. 

4.  Control  Phase  Lock  indicator. 

5.  Calculate  sample  counter  number  corresponding  to  desired  segments  and 
store  them  in  a  table. 

6.  Create  a  table  of  scaled  output  values  for  output  to  hardware  output  ports. 

7.  Output  scaled  values  to  analog  output  ports. 

8.  Control  interrupt  enable/disable  flag. 

None  of  the  above  segments  are  time  dependent  (that  is  they  may  be  done  whenever 
there  is  time  available  after  returning  from  the  foreground  job). 

The  PAM  decom  program  module  waits  in  a  loop  until  the  Phase  Lock  status 
flag  has  been  set  by  the  foreground  job.  Once  lock  has  been  established,  the  frame 
length  counter  is  used  to  determine  a  matrix  of  sample  numbers  corresponding  to 
the  requested  segment  number.  Refer  to  Figure  13  during  the  following  discussion. 

For  a  nominal  2.5X30  NRZ  commutator,  the  number  of  samples  per  frame 
(KL),  at  a  3-ms  sample  rate,  would  be: 

2.  5  frames/s  =  400  ms/frame 

Frame  length  =  f"^S  X  1  3^^  =  133  samples/frame  . 

This  also  gives  a  segment  sample  rate  of: 

400  ms  1  sample  1  .  4. 444  samples 

frame  3  ms  30  segments  ’  segment 

The  sample  number  corresponding  to  a  segment  number  is  then  found  as  follows: 
Sample  No.  Hsegment  no.  -f  3)  X  KL)  +  2  _ 
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DATA  SEG  15  |6  17  ig  19  2021  22  23  24  25  26  27  28  29  0  I  2  3  4  5  6  7  8  9  10  II  12  13  14  15  16  17  18  19 
NO. 


SOFTWARE  I  29 
SEGMENT  NO.  ' 


KO  *  0  AT  0  TO  5  TRANSITION 

Oil  I  2  I  3  |  4  | 


Figure  13.  Sample  PAM  Wavetrain 


For  example,  given: 

Frame  length  KL  =  133 
Segment  No.  1 


KO  Sample  No. 


(1  +  3)  X  133  +  2  =  19.  73  ~  19 


30 


For  the  purposes  of  the  calculations,  the  fractional  part  of  a  result  is  dropped  since 
sample  numbers  are  only  meaningful  in  integer  values.  Sample  No.  19  would  then 
correspond  with  the  value  of  segment  no.  1.  All  segments  are  sampled  toward  the 
end  of  the  segment  period  to  allow  for  slow  rise  time  in  the  telemetry  system  and 
to  allow  any  ringing  to  be  dampened  out.  Figure  13  shows  the  relation  between 
frame  length,  software  segment  number,  data  segment  number,  and  sample  num¬ 
ber,  with  an  expanded  view  of  the  sync  pattern. 
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*.1 


After  the  sample  number  matrix  has  been  created,  the  sampled  segment 
values  are  scaled  for  output  such  that  digital  output  counts  are  equivalent  to  the 
following  values: 

1  count  =  27.  3  mV 


Count 

Voltage 

00 

-1.  00 

36 

0.  00 

127 

2.  50 

219 

5.00 

255 

+  6.00 

Figure  14  also  shows  this  relationship  in  graphic  form.  This  range  exceeds  the 
normal  commutator  voltage  by  ±20  percent,  but  occasional  out  of  range  values  have 
been  experienced,  and  the  output  device  should  reflect  this  fact. 


Figure  14.  Output  Scaling  for  D/A  Ports 


The  scaling  routine  is  a  proportional  relationship  based  on  the  input  A/D  count 
determined  by  the  foreground  job  at  the  0  and  5-V  points. 

The  following  relationship  is  used: 


D  to  A  =  <2Ig--- ffjXjData  -  Zero) 
;  r  ive  -  Zero) 


where 


Zero  =  A/D  counts  at  0-V  input 
Five  -  A/D  counts  at  5-V  input 
Data  =  A/D  counts  at  desired  segment  number. 
As  an  example,  and  referring  to  Figure  14,  given: 
Zero  =110 


Five  =182 
Data  =  120 


D  to  A 


(219  -  36)  X  (120  -  110)  , 

- (182' -Tlffi -  +  36-61 


A  digital  count  of  61  sent  to  the  appropriate  digital  to  analog  output  device  will 
result  in  an  output  voltage  of  0.69  V.  All  requested  segment  numbers  are  scaled 
and  sent  to  their  respective  output  port  in  turn. 

4.3.2  FOREGROUND  JOB 

The  PAM  foreground  job,  commonly  referred  to  as  the  interrupt  service  rou¬ 
tine,  executes  the  time-dependent  parts  of  the  decom  task.  Once  the  system  has 
been  initialized  and  interrupts  are  allowed  to  occur  (that  is,  the  interrupt  line  is 
enabled),  a  hardware  timer  counts  down  from  a  predetermined  value  and  causes  an 
interrupt  pulse  to  be  generated  every  3  ms.  The  interrupt  pulse  causes  the  proc¬ 
essor  to  interrupt  the  task  being  performed  and  transfer  control  to  the  foreground 
program.  All  background  code  is  reentrant,  that  is,  it  may  be  interrupted  and 
then  resumed  after  servicing  the  interrupt  without  losing  any  intermediate  data  or 
affecting  the  results.  Figures  If),  16,  and  17  show  the  sequence  of  events  that 
occur  in  response  to  the  interrupt.  Figure  18  is  a  list  of  variables  that  should  be 
referred  to  during  the  following  discussion. 

Before  the  system  can  find  sync,  it  must  take  256  samples,  or  almost  two 
complete  frames,  in  order  to  determine  the  highest  and  lowest  input  values  with 
which  it  must  work.  Four  sequential  samples  are  averaged  and  used  to  update  HI 
and  I.O.  These  two  values  may  be,  but  are  not  necessarily,  the  values  correspond¬ 
ing  to  the  0  and  5-V  segments.  Once  HI  and  1,0  are  found,  a  flag  is  set  and  all 
further  input  values  are  expanded  such  that  HI  equals  a  count  of  255  and  DO  equals 
a  count  of  0.  It  is  this  feature  that  allows  the  input  to  the  system  to  be  set  over  a 
wide  voltage  range  with  no  effect  on  the  output  data. 

The  program  now  proceeds  to  check  subsequent  samples  for  a  valid  sync  pat¬ 
tern,  as  shown  in  Figure  16.  ( )nce  a  required  voltage  level  or  transition  is  detected, 

the  associated  flag  bit  is  set  and  the  program  flow  returns  to  the  background  program. 


FOREGROUND  JOB  FLOWCHART 


Figure  15.  Foreground  Job  Flowchart 
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PHASE  LOCK 

(7) 


AHEAD? 


Y  \  N 

— <  V3»5  > — 


NORMAL? 


N  /  \  Y 

— <T  V4 » 5  >— 


I  sample 
AHEAD  ? 


NORMAL 


ADJUST  COUNTER 
KO  *  2 


I  AHEAD 

ADJUST  COUNTERS 
KO  =  3 
KL  =  KL - 1 


LOST  LOCK 


Figure  17.  Phase  Fork  Flowchart  (Sheet  2) 


Label 


FO 

Flagword  0 

FI 

Flagword  1 

V 

Current  A/D  input  voltage  (V(N)) 

VI 

Previous  input  voltage  (V(N-l)) 

V2 

V(N-2) 

V3 

V(N-3> 

V4 

V(N-4> 

V5 

V(N~5) 

V6 

V(N-G) 

KO 

Interrupt  counter 

K1 

Counter 

KL 

Counts  between  sync  (frame  length) 

ZERO 

A/D  at  0-V  segment 

FIVE 

A/D  at  5-V  segment 

ZEROO 

Last  zero 

FIVEO 

Last  five 

KZERO 

Clock  at  zero 

KFIVE 

Clock  at  five 

LO 

Smallest  A/D 

HI 

Largest  A /D 

RAW 

Raw  A /D  value 

RAWLO 

Raw  LO  A  / D  value 

RAWHI 

Raw  HI  A/D  value 

KLO 

Old  value  of  K1 . 

Tables 

TAB2  Desired  segment  numbers 

TAB  Clock  count  to  sample  TAB2 

DATA  A/D  count  corresponding  to  TAB 

DIOA  D/A  VALVE  (  cor  reeled /scaled)  for  output 

Figure  18.  List  and  Definition  of  Variables 

Upon  reentry  at  the  next  interrupt,  the  program  checks  its  progress  by  testing  the 
flags,  and  proceeds  directly  to  the  next  step  in  the  sync  detection  process.  If  at 
any  time  a  particular  test  fails,  it  is  either  checked  again  at  the  next  interrupt 
time,  or  the  flags  are  reset  and  the  process  begins  again.  Figure  19  lists  the  flag 
bits  and  their  significance. 


0  Phase  Locked 

1  Pound  a  Zero 

2  Found  a  Zero  to  Five  Transition 

3  Found  First  Sync  Pattern 

4  Found  a  Zero,  possible  start  of  second  sync 

5  Found  Second  Zero  to  Five  Transition 

6  Not  Used 

7  Not  Used 

Flag  Word  1 
Bit 

0  Taken  255  samples  and  found  LO  and  HI 

1  Not  Used 

2  Found  LO  and  HI  and  initialized  KO  Counter 

3  Not  Used 

4  Not  Used 

5  Not  Used 

6  Found  First  Zero 

7  Found  First  Five 

Figure  19.  Flag  Bit  Assignment 

Once  a  second  sync  word  is  found  within  a  10  percent  window  of  one  frame 
length  from  the  first  sync  word,  the  system  indicates  sync  lock  and  proceeds  to 
process  data.  This  window  allows  up  to  a  10  percent  variation  in  the  sampling  rate 
of  the  commutator  befc;e  it  will  drop  sync.  Present-day  solid  state  commutators, 
unlike  the  earlier  mechanical  variety,  do  not  exhibit  these  large  speed  changes, 
but  this  allows  the  system  to  process  data  from  any  commutator  running  within 
±10  percent  of  the  2.  5  X  30  rate. 

Once  each  frame  the  relative  position  of  the  sync  word  0  to  5-V  transition  is 
compared  with  that  of  the  last  frame.  This  is  the  phase  lock  program  module  shown 
in  Figure  17.  The  program  allows  and  will  correct  for  a  change  of  ±2  interrupt 
pulses,  or  6  ms,  before  it  drops  back  to  the  sync  detection  routine. 

Figure  20  shows  the  acceptable  range  of  phase  lock  and  the  corrections  applied 
in  each  case.  If  the  routine  determines  that  the  previously  measured  frame  length 
was  too  long,  it  will  subtract  1  or  2  from  the  frame  length  counter  KL.  If  the 
frame  length  was  too  short,  1  or  2  will  be  added  to  the  counter  as  appropriate.  At 
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the  same  time,  the  sample  or  interrupt  counter  KO  is  preset  to  the  correct  sample 
number.  A  change  of  more  than  ±2  is  considered  unacceptable,  and  the  system 
drops  out  of  sync  and  begins  the  process  again.  This  change  in  KL  is  taken  into 
account  on  each  pass  through  the  background  PAM  routine  when  the  sample  number 
vs.  segment  number  table  (TAB)  is  created. 


Figure  20.  Phase  Lock  Samples 

5.  DISCUSSION  OF  RF.SULTS 

working  prototype  system  has  been  designed,  built  and  field-tested  during  a 
series  ■  r  high-altitude  balloon  launches  for  project  BAMM.  The  system  has  also 
been  u.,od  r>>r  data  reduction  for  post -flight  analysis.  This  experience  has  pointed 
out  where  various  changes  could  be  made  to  the  system.  As  with  many  systems 
involving  software,  there  always  seems  to  be  another  small  change  availabe  to 
make  the  system  a  little  better.  The  major  software  change  to  be  made  involves 
a  query  from  the  video  terminal  or  a  front  panel  switch  which  will  bypass  the  BASIC 
program  and  output  to  the  video  terminal  and  printer.  This  will  allow  the  system 
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to  be  used  as  a  standalone  decommutator  to  drive  a  paper  chart  recorder.  Up  to 
!t>  segment  numbers  would  be  entered  from  a  front  panel  numeric  keypad. 

Other  changes  involve  hardware  simplification.  Since  this  project  was  started, 
advances  in  A  D  and  D/A  conversion  hardware  have  been  made  which  would  simplify 
the  interface  by  allowing  these  devices  to  be  connected  directly  to  the  processor 
bus. 

The  final  model  should  not  use  a  KIM-board,  but  would  contain  a  processor 
board  specifically  designed  for  the  system.  This  would  eliminate  parts  of  KIM 
which  are  not  used,  such  as  the  keyboard  and  display. 

Address  decoding  could  be  simplified  to  decode  only  those  blocks  of  address 
that  would  be  used  in  the  final  system.  Complete  decoding  would  not  be  necessary. 

Finally,  the  system  could  be  constructed  in  a  cabinet  sized  to  hold  a  common 
plug  in  card  size  to  facilitate  changes  and  servicing.  The  resident  software  in 
EPROM  could  be  on  one  card  which  would  be  easily  interchanged  when  software 
modifications  are  to  be  made. 

A  final  model  is  presently  under  design  which  will  include  these  changes.  This 
model  will  be  assembled  and  tested  as  time  permits. 

6.  CONCLUSION 

Construction  of  this  development  and  prototype  system  has  demonstrated  the 
feasibility  of  applying  a  microprocessor  to  the  field  of  telemetry  data  handling.  It 
also  shows  the  power  and  versatility  available  from  a  combination  of  hardware  and 
software.  This  project  has  been  an  intriguing  learning  experience  into  the  field  of 
microprocessors.  The  knowledge  and  experience  gained  during  this  project  will  be 
applied  to  further  the  state  of  the  art  of  telemetry  system  support  in  the  future. 
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BASIC  PAM  PROGRAM 


10  GOSUB  2000 

20  DIM  DC  29 )  iRE.4  A"  D  COUMTS 

25  DIM  Li ( 29  > :  REM  LABELS 

26  DIM  A4  (l)i  R  EM  DAY  /  DATE  STRING 
28  DIM  VC29) »REM  SCALED  0-5  'N3LTS 

30  POKE  825  6'203tPOX£  8257/193 
35  X«USRC  0) 

40  PRINT 

41  PRINT 

42  PRINT 

45  LET  A4=“  VEDMESDAY  8  OCTOBER  1960“ 

50  PRINT  T  ABC  5  "BAM.l  PAYLOAD  STATUS ’/Ai 
60  PRINT 
62  PRINT 

65  LET  Z-PEEKC94  4) 

66  LET  F-PEEKC94  5) 

70  FOR  1=  0  TO  29 

80  LET  A»P  EEKC828*  I  ) 

85  LET  DC  I  >*A 
90  GOSUB  1000 
95  LET  VC  I >  *  A 
100  READ  LiCI) 

110  NEXT 

115  IF  VC  1  )=  0THEN  IF  VC2)  =  0THE.N  PRINT  TAB  C  1  5  )  S  “  S 1 M”LA~ED 

116  IF  VC1)>0  THEN  PRINT* 

I  18  PRINT 

210  LET  A=  VC1  >«2.85+  19 
212  GOStJB  10  10 

216  PRINT  “  01  “  "Cl  JJTABC  15>iLiC  1  >-*“A“”OL-rS 

220  LET  A=  VC2)*2. S4*20-51 
222  GOSUB  1010 

228  PRINT  *  02  “VC2J/TABC  15>IL4C2->“*“A“  ,DL‘rS 

240  LET  A»VC4J 

242  GOSUB  1 1 10 

244  GOSUB  1  0  10 

246  GOSUB  2400 

248  PRINT  “  04  “  VC  41 S T  ABC  1 5 )  i  L» C 4 > “ *“ A" C  */T“F 

250  LET  A=VC5> 

252  GOSUB  1110 
254  GOSUB  1010 
256  GOSUB  2400 

256  PRINT  “  05  "VC5UTABC  15JJL4C5)"«"A“C  */T"F 

260  LET  A=VC6> 

262  GOSUB  1110 
264  GOSUB  1010 
266  GOSUB  2400 

268  PRINT  "  06  *pC6;;TABC  1 5>;LiC6>“  =  ’A“C  “fT*F 

27  0  LET  A=  VC  7  > 

272  GOSUB  1110 
274  GOSUB  1010 
276  GOSUB  2400 

278  PRINT  “  07  *  VC  7 ) J ~ ABC  1 5 >  I  Li C 7 > " »* A" C  "*~"F 

300  IF  VC 17>< • 2  THEN  GOTO  2300 
360  LET  A*  VC  16) 

362  GOSUB  1110 
364  GOSUB  1010 
366  GOSUB  2400 

368  PRINT  "  16  ’  VC  1  6)  J T ABC  1 5 >  ;  LiC l 6) A“ C  *jT’F 

370  LET  A«  VC  1  7)»4.88-3.73 
372  GOSUB  1010 

376  PRINT  *  17  " VC  1 7 >J TABC 1 5>  I  LiC 1 7) “«“A”PS1 
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380  IF  V(  I9X.2THE)  GOTO  2200 
390  LET  A»  V<19  )*<- 21  •  614X258.07 
392  GOSUB  1010 

398  PRINT  “  19  "  Vt  19 ) l T ABU  5 ) J L*C 1 9 ) *»“A"K 

400  LET  A*  VC20  >• C-  18  •  66>+30  « 1 
402  GOSUB  10  10 

408  PRINT  “  20  " Vt20 > ; T AB< 1 5 > t LSC 20 ) *-"A"C 

440  LET  A«  V(24>*<-9.  66>+ 121 .4 
442  GOSUB  1010 

448  PRINT  "  24  “ V (24 > IT ABU  5 > 1  LSI 24) * »"A"K 

450  LET  A»  VC25  >*<- 165+49 
452  GOSUB  1010 

458  PRINT  *  25  *  V<25  >1 T  ABU  55  J  L»<  25  5  "  »"A“C 

522  PRINT 

524  PRINT  “  SYNC“J V(265J V(275;  V(285; VI295; V<0  5; " 

530  RESTORE 
540  GOT 030 

1000  LET  A«S*tA-t)/< F-Z) 

1010  LET  A* INT<A* 10  0+ • 51/  100 
1020  RETURN 

1100  REM  SUBROUTINE  TO  SCALE  LCR  TEMP  MON. 

1110  1 F  A<  1  THEN  LET  A=  l  05 • 34- ( 45 • 5*A5 : RETURN 
1120  I  F  A« l .8  THEN  LET  A* 8 6 .95* < 2 6. 9 5*A5 ! RETURN 
1130  IF  A«3-8  THEN  LET  A»  75  •  62  -  U  9  •  75  + A )  I  RETURN 
1140  IF  A< 4. 5  THEN  LET  A« 1 09 • 42“ <  28 • 5 7* A) t  RETURN 
1150  LET  A»2S4  •  18-  (  60-  6»A5  :  RETURN 
2000  REM  SUBROUTINE  TO  CLEAR  SCREEN 
2010  POKE  825  6.235  :P  OKE  8257.  193 
2020  X  =  U SR  (  0  > 

2030  RETURN 

2200  1  F  V(20  5<  .2  THEN  GOTO  2210 
2205  GO'r  O  390 

2210  IF  VC24 )<  .2  THEN  GOTO  2220 
2215  GOTO  390 

2220  IF  VC25X.2  THEN  GOTO  2230 
2225  GOTO  390 

2230  PRINT  "  19  "V<195;TABU55J  "RADIOMETER  OFF 

2240  PRINT  "  20  "  V(20  )J  " 

2250  PRINT  "  24  "V(245J" 

2260  PRINT  "  25  "VI255J" 

2270  GOTO  522 

2300  PRINT  “  16  "  V(l  6 5  J  TABU  5  5  I  "T  V  CAMERA  OFF 

2310  PRINT  *  17  "  VU  7 );  ’ 

2320  GOTO  380 

2400  REM  SUB  TO  CONVERT  C  TO  F 
2410  LET  T » (9#  A5  / 5+  32 
2420  LET  T»INT(T+1 0+ • 5)/ 10 
2430  RETURN 
3000  DATA  SYNC 

30  10  DATA  TM  BATT  #  l  .  TM  BATT  *2.  SPARE 

3020  DATA  LINK  1  TEMP. LINK  2  TEMP. LINK  3  TEMP. LI MK  4  TEMP 

30  30  DATA  SPARE.  SPARE.  SPARE.  SPARE 

3040  DAT  A  SPARE.  SPARE.  SPARE.  SPARE 

3050  DATA  TV  CAMERA  TEMP.T”  CAMERA  PRESSURE 

30  60  DATA  SPARE.  RAD  DET  TEMP. RAD  BAFFLE  TEMP 

3070  DATA  SPARE.  SPARE.  SPARE 

3080  DATA  RAD  FINGER  TEMP. RAD  MOTOR  TEMP 

3090  DATA  SYNC.  SYNC.  SYNC.  SYNC 

4000  END 
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SAMPLE  OUTPUT 


jjf^CgftUKs  faflfc  lUkWlWWT  Fli^W 


t 


BAMM  RAYE-OAD  STATUS 


WEDNESDAY  :3  OCTOBER  1979 


276  s  13  i  50  i 

11  CDT 

01 

3.  17 

TM  BATT  *1=  28.03  VOLTS 

02 

2.91 

TM  BATT  «2  =  27.9  VOLTS 

03 

2.62 

CMND  TEMP=  23.1  C 

73.6  F 

04 

2.04 

LINK  1  TEMP=  33.97  C 

93.1  F 

05 

1.87 

LINK  2  TEMP=  37.16  C 

98.9  F 

06 

1.96 

LINK  3  TEMP-  35.47  C 

95.8  F 

07 

1.98 

LINK  4  TEMF=  35.1  C 

95.2  F 

08 

2.4 

TM  BATT  #1  TEMP=  27.22  C 

81  F 

13 

2.47 

INTER  BATT  «1  =  ,’8.38  VOLTS 

14 

1.85 

MONITOR  TEMP--  37.53  C 

99.6  F 

15 

2.  32 

INTER  BATT  -2=  32. 58  VOLTS 

16 

.  02  TO 

CAMERA  OFF 

17 

0 

ie 

3.4 

RAD  BATT=  27.64  VOLTS 

19 

- .  36 

RAO  OUT  TEMP=  265.85  K 

20 

-.36 

RAD  BAFFLE  TEMP=  309.82  K 

24 

-  .  36 

RAO  FINGER  TEMP=  124.88  K 

2  r» 

1.09 

RAD  FILTER  TEMP'-  304.56  K 

SYNC  O 


06  5 .  02 


2.  51 


ACIA 

A/  D 

ASCII 

BA  MM 

BCD 

CRT 

D/A 

EPROM 

I/O 

K 

KIM 

LSD 

MSD 

NRZ 

PAM 

PIA 

ROM 

RZ 

SCO 


List  of  Abbreviations 


-  Asychronous  Communications  Interface  Adapter 

-  Analog  to  Digital  Conversion 

-  American  Standard  Code  for  Information  Interchange 

-  Balloon  Altitude  Mosaic  Measurement 

-  Binary  Coded  Decimal 

-  Cathode  Ray  Tube 

-  Digital  to  Analog  Conversion 

-  Eraseable-Programmable  Read  Only  Memory 

-  Input /Output 

1024;  KBYTE  =  1024  memory  bytes  =  1024  X  8  bits 
Keyboard  Interface  Module 
Least  Significant  Digit 

-  Most  Significant  Digit 

-  Non-Return  to  Zero 

-  Pulse  Amplitude  Modulation 

-  Peripheral  Interface  Adapter 
Read  Only  Memory 

Return  to  Zero 
Sub-Carrier  Oscillator 
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